草庐IT

iOS Webkit 忽略媒体查询

全部标签

ruby - 如何让 rspec 不显示数据库查询而只显示带有 rails_12factor 的点?

ruby:2.0rails:3.2.17rspec:2.14.8Database:mysqlrspecspec用于仅输出点。当我推送到Heroku并且最近添加了rails_12factorgem来绕过它时,我收到了弃用警告。但是,现在在本地运行规范时,我会得到每个事务的详细数据库输出。当我需要它时这是一个很好的选择,否则它会产生很多不需要和分散注意力的输出。所以我想要一个将它用于Heroku而不是本地的选项。请注意,这不会通过使用格式化程序来解决,例如rspecspec-fd此外,如果出现错误,在这种冗长程度下,错误几乎总是滚出当前页面...09:50:39durrantmCastle

ruby-on-rails - Rails 查询执行导致数据库峰值

我的Rails应用程序出现问题,一些随机查询需要大约5秒或更长时间才能完成。大多数时候,查询非常简单(select*fromxwhereid=?),而且字段甚至也被编入索引。这里有一些关于设置的更多信息:反向nginx代理背后的Puma3.5.04个worker,每个worker最少4个,最多8个线程。Rubyv2.2.3,Railsv4.2.4PostgreSQL9.4数据库线程池设置为最多60个连接监控应用8GBRAM、4个CPU、SSD。我在查看Appsignal中的查询性能时发现了这一点。我注意到大多数查询在几毫秒内完成,然后时不时地,仍然在同一个请求中,有多个查询需要5秒以上

ruby-on-rails - 在 Rspec 中用项目符号标记 N+1 查询

我正在尝试使用bulletgem标记N+1并在代码中添加计数器缓存的位置.但是手动执行所有检查N+1查询的操作似乎非常痛苦,所以我尝试使用Bullet和Rspec,使用他们推荐的设置步骤:#config/environments/test.rbconfig.after_initializedoBullet.enable=trueBullet.bullet_logger=trueBullet.raise=true#raiseanerrorifn+1queryoccursend#spec/spec_helper.rbifBullet.enable?config.before(:each)d

ruby-on-rails - ActiveRecord:查询未对 STI 子类使用正确的类型条件

我有一组STI子类继承自User基类。我发现在子类定义中的某些条件下,对子类的查询没有正确使用type条件。classUser在开发中加载Rails控制台时,它会按照我的预期进行:Admin:SELECT`users`.*FROM`users`WHERE`users`.`type`IN('Admin')但是当点击应用程序(localhost/pow)时,它缺少type条件,我明白了:Admin:SELECT`users`.*FROM`users`但在部署到暂存服务器时不是来自应用程序:Admin:SELECT`users`.*FROM`users`WHERE`users`.`type`

ruby - Thor 可执行文件 - 忽略任务名称

雷神维基页面,MakinganExectable,向您展示了如何创建一个看起来像这样的thor支持的CLI命令:庆典./mythorcommandfoo这需要您将thor任务foo作为第一个参数传递。我还可以使用thor的default_method运行不带任何参数的thor可执行文件:庆典./神话命令但是,我想传入一个可变字符串作为第一个参数:庆典./mythorcommand"somevalue"这不起作用,因为thor命令期望第一个参数是任务名称。有没有办法忽略任务名称并将第一个参数发送到默认方法?如果这个功能不存在,我认为添加一个将所有命令行参数传递到一个任务/方法中的方法会非

ruby-on-rails - 将方法委托(delegate)给 has_many 关联会忽略预加载

是否可以将方法委托(delegate)给Rails中的has_many关联,并且仍然将预加载的数据保存在该关联上,同时遵循得墨忒耳法则?目前在我看来,你被迫选择一个或另一个。也就是说:通过不委托(delegate)来保留预加载的数据,或者丢失预加载的数据和委托(delegate)。示例:我有以下两个模型:classUser注意:User#all_blogs_have_title?做的事情与all_have_title?的委托(delegate)方法完全相同。据我了解,以下内容违反了得墨忒耳定律。但是:它会保留您预加载的数据:user=User.includes(:blogs).firs

ruby - 如何使用 RSpec should_receive 忽略额外的消息?

规范:beforedoLogger.should_receive(:write).with'Logmessage1'endit'works'doget'/'endSinatra应用程序:get'/'Logger.write('Logmessage1')Logger.write('Logmessage2')end由于“日志消息2”,此规范失败。如何告诉RSpec忽略任何其他消息,只测试预期的消息? 最佳答案 您需要在消息预期之前对将接收消息的方法进行stub。#RSpecstubmethodisdeprecatedinRSpec3,而

ruby-on-rails - 让 Rails 2.3.x 忽略 i18n gem

我有一个使用Rails本地化功能的Rails2.3.5项目。我也碰巧安装了Rails3beta(这取决于i18ngem)。Rails2.3.5会愉快地自行处理本地化(没有安装i18n),但是如果i18ngem可用,它会使用它。最近我升级了我的gem,现在安装了i18n的0.3.7和0.4.0版本。当然,Rails想要加载和使用导致我的项目出错的最新版本。我尝试将gem版本设置为0.3.7以解决网络应用程序中的错误。但是,我们使用resque和resque_mailer来延迟消息的发送。当工作人员从队列中选取邮件程序作业时,它会忽略我在environment.rb中的config.gem

ruby 字符串匹配忽略大小写

我正在尝试创建一个匹配查询,它从两个单词之间的字符串中选择文本。我似乎无法弄清楚如何使搜索不区分大小写。例如考虑文本:contents="catLoremipsumdolorsitamet,consecteturadipiscingelit.Donecblanditfeugiatmi,eulaciniaquamtincidunteu.Doneceleifendadipiscingneque,inportadolorvestibulumat.Curabituridelitvitaenuncfeugiatvarius.Maecenaseuismodeuismodmi,eublanditle

ruby-on-rails - 为什么 foreman gem 会忽略 PORT 环境变量?

我希望工头gem使用我的开发环境文件中提供的PORT值,而不是使用它自己的值。我的文件设置如下所示:启动工头的bash脚本:foremanstart-edevelopment.envdevelopment.env文件内容:端口=3000Procfile内容web:bundleexecrailsserverthin-p$PORT-e$RAILS_ENV$1开发服务器最终在端口5000上启动。我知道我可以用--p3000启动工头以强制它使用该端口。但这违背了env文件的目的。有什么建议吗? 最佳答案 我知道这是一篇旧帖子,但我花了一段时